#### PATENT ABSTRACTS OF JAPAN

(11) Publication number: 11003223 A

(43) Date of publication of application: 06.01.99

(51) Int. CI

G06F 9/06 G06F 3/12

(21) Application number: 09152646

(22) Date of filing: 10.06.97

(71) Applicant:

**CANON INC** 

(72) Inventor:

ONIZUKA YASUYUKI MATSUMOTO MASASHI

# (54) INFORMATION PROCESSOR AND INFORMATION STORAGE METHOD

#### (57) Abstract:

PROBLEM TO BE SOLVED: To provide an information processor and an information storage method capable of securing the reliability of input information from an external device.

SOLUTION: A flash ROM (ER) is divided into plural sector blocks(SBs) and a program module(PM) is written from a host to respective SBs. In the case that abnormality is generated in the host during down-loading, the possibility that data inside the SB of the FR are destroyed is high. Then, a program inside a boot block is set so as not to activate the SB storing the PM at the time of the reactivation of the next time. Thereafter, by the reactivation of a printer, the check sum (CS) of the respective SBs stored in a RAM until then is cleared and the CS stored in the FR is newly stored in the RAM. By the difference of the CS inside the Ram and a normal CS held by the host, the program to be down-loaded again is determined.



# (19) 日本国特許庁 (JP)

9/06

3/12

# (12) 公開特許公報(A)

(11)特許出願公開番号

# 特開平11-3223

(43)公開日 平成11年(1999)1月6日

(51) Int.Cl.<sup>6</sup> G 0 6 F 識別記号

540

FΙ

G06F 9/06

540M

3/12

Α

審査請求 未請求 請求項の数15 OL (全 13 頁)

(21)出願番号

(22)出願日

特願平9-152646

平成9年(1997)6月10日

(71)出願人 000001007

キヤノン株式会社

東京都大田区下丸子3丁目30番2号

(79) \$

(72)発明者 鬼塚 康如

東京都大田区下丸子3丁目30番2号 キヤ

ノン株式会社内

(72)発明者 松本 正史

東京都大田区下丸子3丁目30番2号 キヤ

ノン株式会社内

(74)代理人 弁理士 大塚 康徳 (外2名)

# (54) 【発明の名称】 情報処理装置及び情報格納方法

### (57) 【要約】

【課題】 外部装置からの入力情報の信頼性の確保が可能な情報処理装置及び情報格納方法の提供。

【解決手段】 フラッシュROM(FR)を複数のセクタブロック(SB)に分割し、その各SBにホストからプログラムモジュール(PM)を書き込む。ダウンロード中にホストに異常が発生した場合、FRの当該SB内のデータは破壊されている可能性が高い。そこで、そのPMが格納されているSBが次回の再起動時に起動されないように、ブートブロック内のプログラムを設定する。その後、プリンタの再起動により、それまでRAMに格納されていた各SBのチェックサム(CS)はクリアされ、FRに格納されているCSがRAMに新たに格納される。このRAM内のCSとホストが持っている正規のCSとの相違により、再度ダウンロードすべきプログラムを判断できる。



# 【特許請求の範囲】

【請求項1】 複数の格納領域を有し、その格納領域毎に書き込み・消去が可能な不揮発性のメモリ手段と、 外部装置との双方向通信が可能な通信手段と、

前記メモリ手段のそれぞれの格納領域への書き込み順序 を制御する制御手段とを備え、前記メモリ手段には、前 記格納領域毎に複数のモジュールに分割された装置の動 作プログラム及びデータが格納され、前記制御手段は、 前記外部装置から前記動作プログラム及びデータの更新 が指示された場合に、前記外部装置から受信する複数の モジュールに分割された動作プログラム及びデータのそ れぞれを、前記メモリ手段の何れかの格納領域に格納す ることを特徴とする情報処理装置。

【請求項2】 更に、前記通信手段により受信したモジュールのそれぞれについてチェックサムを算出するチェックサム算出手段を備え、前記制御手段は、前記チェックサム算出手段によりモジュール毎に算出したチェックサムを、そのモジュールと共に、前記メモリ手段の何れかの格納領域に格納することを特徴とする請求項1記載の情報処理装置。

【請求項3】 前記メモリ手段は、前記情報処理装置の 起動時に、前記複数の格納領域に格納しているそれぞれ のモジュールのチェックサムを、前記外部装置が参照可 能な一時記憶メモリにコピーすることを特徴とする請求 項2記載の情報処理装置。

【請求項4】 前記データは、そのデータが含まれるモジュールのチェックサムを含んでおり、

更に、前記通信手段により受信したモジュール内の動作プログラムのチェックサムを、そのモジュールについて前記チェックサム算出手段により算出したチェックサムと比較する比較手段を備え、前記制御手段は、前記比較手段によりチェックサムが一致しないモジュールを、前記通信手段により前記外部装置に報知することを特徴とする請求項2記載の情報処理装置。

【請求項5】 前記複数のモジュールは、前記情報処理 装置を制御する動作プログラムであることを特徴とする 請求項2記載の情報処理装置。

【請求項6】 前記メモリ手段の複数の格納領域において、少なくとも1つの領域は書き込み禁止に設定し、その書き込みを禁止した領域に少なくとも前記外部装置との通信制御プログラム、前記メモリ手段の書き込み制御プログラム、並びに前記制御手段によるモジュールの書き込みが中断したときのエラー処理プログラムを予め格納することを特徴とする請求項5記載の情報処理装置。

【請求項7】 前記制御手段は、前記エラー処理プログラムにより、モジュールの書き込みが所定時間を超えて中断したときに書き込みを中止し、書き込みを中断した格納領域が起動されないように制御することを特徴とする請求項1記載の情報処理装置。

【請求項8】 更に、前記制御手段によるモジュールの書き込み指定アドレスを変換するアドレス変換手段を備え、そのアドレス変換手段が、前記制御手段があるモジュールを書き込むときに、そのモジュールを、前記複数の格納領域の内、現在空き領域となっている格納領域に格納するようにアドレスを変換し、そのモジュールを本来格納すべき格納領域を新たな空き領域とすることを特

【請求項9】 前記アドレス変換手段は、前記情報処理 10 装置の再起動後も、再起動前のアドレス変換状態を保持 することを特徴とする請求項8記載の情報処理装置。

徴とする請求項1記載の情報処理装置。

【請求項10】 前記メモリ手段に、フラッシュメモリを使用することを特徴とする請求項1記載の情報処理装置

【請求項11】 前記通信手段の通信プロトコルは、I EEE1284規格の双方向セントロニクスパラレルインターフェースであり、ECPモードにて使用することを特徴とする請求項1記載の情報処理装置。

【請求項12】 前記情報処理装置は、プリンタである 20 ことを特徴とする請求項1記載の情報処理装置。

【請求項13】 複数の格納領域を有する不揮発性のメモリを使用して、その格納領域毎に情報を格納する情報格納方法であって、

前記メモリの格納領域毎に複数のモジュールに分割された装置の動作プログラム及びデータを格納し、

外部装置から前記動作プログラム及びデータの更新が指示された場合に、その外部装置から受信する複数のモジュールに分割された動作プログラム及びデータのそれぞれを、前記メモリの何れかの格納領域に格納することを特徴とする情報格納方法。

【請求項14】 複数の格納領域を有するメモリに、所 定の格納領域が予め決められている入力情報を格納する 情報格納方法であって、

前記メモリの複数の格納領域の内、少なくとも1つを空 き領域に設定し、

その空き領域に入力情報を格納し、

その格納した入力情報を、その入力情報の所定の格納領域にコピーすることを特徴とする情報格納方法。

【請求項15】 複数の格納領域を有するメモリに、所 の 定の格納領域が予め決められている入力情報を格納する 情報格納方法であって、

前記メモリの複数の格納領域の内、少なくとも1つを空 き領域に設定し、

その空き領域に入力情報を格納し、

その格納した入力情報が本来格納されるべき所定の格納 領域を、新たな空き領域に設定することを特徴とする情 報格納方法。

【発明の詳細な説明】

[0001]

50 【発明の属する技術分野】本発明は、例えば、外部機器

30

(3)

3

から受信した入力情報を処理する情報処理装置及び情報 格納方法に関する。

#### [0002]

【従来の技術】代表的な情報処理装置であるプリンタにおいては、プリンタの制御を司るCPUや、ASICの動作制御プログラムを格納するメモリに、一般にマスクROMやEPROM等が利用されている。

#### [0003]

【発明が解決しようとする課題】しかしながら、マスクROMやEPROMは、プログラムを一度書き込むと消去ができないため、プログラムのバージョンアップ、或いはプログラムに不具合が発見された場合等にはROM自体を取り替える必要が生じる。特に、プリンタは、印字ヘッド等の可動部分が多く、一般ユーザではROMの交換が困難なため、交換の際はサービスマン対応となり、コスト、時間がかかるという問題がある。

【0004】そこで本発明では、上記のプログラムのような必要な情報を予め自装置内のROMに格納するのは止め、その必要な情報を外部装置から入手する。特に、その情報の入手の際、外部装置からの入力情報の信頼性の確保が可能な情報処理装置及び情報格納方法の提供を目的とする。

# [0005]

【課題を解決するための手段】上記の目的を達成するため、本発明の情報処理装置は以下の構成を特徴とする。

【0006】即ち、複数の格納領域を有し、その格納領域毎に書き込み・消去が可能な不揮発性のメモリ手段と、外部装置との双方向通信が可能な通信手段と、前記メモリ手段のそれぞれの格納領域への書き込み順序を制御する制御手段とを備え、前記メモリ手段には、前記格納領域毎に複数のモジュールに分割された装置の動作プログラム及びデータが格納され、前記制御手段は、前記外部装置から前記動作プログラム及びデータの更新が指示された場合に、前記外部装置から受信する複数のモジュールに分割された動作プログラム及びデータのそれぞれを、前記メモリ手段の何れかの格納領域に格納することを特徴とする。

【0007】更に好ましくは、前記制御手段によるモジュールの書き込み指定アドレスを変換するアドレス変換手段を備え、そのアドレス変換手段が、前記制御手段が 40 あるモジュールを書き込むときに、そのモジュールを、前記複数の格納領域の内、現在空き領域となっている格納領域に格納するようにアドレスを変換し、そのモジュールを本来格納すべき格納領域を新たな空き領域とするとよい。

【0008】または、上記の目的を達成するため、本発明の情報格納方法は以下の構成を特徴とする。

【0009】即ち、複数の格納領域を有する不揮発性の メモリを使用して、その格納領域毎に情報を格納する情 報格納方法であって、前記メモリの格納領域毎に複数の モジュールに分割された装置の動作プログラム及びデータを格納し、外部装置から前記動作プログラム及びデータの更新が指示された場合に、その外部装置から受信する複数のモジュールに分割された動作プログラム及びデータのそれぞれを、前記メモリの何れかの格納領域に格納することを特徴とする。

【0010】即ち、複数の格納領域を有するメモリに、 所定の格納領域が予め決められている入力情報を格納す る情報格納方法であって、前記メモリの複数の格納領域 10 の内、少なくとも1つを空き領域に設定し、その空き領 域に入力情報を格納し、その格納した入力情報を、その 入力情報の所定の格納領域にコピーすることを特徴とす る。

【0011】即ち、複数の格納領域を有するメモリに、 所定の格納領域が予め決められている入力情報を格納す る情報格納方法であって、前記メモリの複数の格納領域 の内、少なくとも1つを空き領域に設定し、その空き領 域に入力情報を格納し、その格納した入力情報が本来格 納されるべき所定の格納領域を、新たな空き領域に設定 することを特徴とする。

#### [0012]

【発明の実施の形態】以下、本発明を代表的な情報処理 装置としてのプリンタに適用した実施形態を、図面を参 照して詳細に説明する。

【0013】はじめに、本願では、ホストコンピュータ等の外部機器から受信する印刷データ及び制御データのインタフェースとして、一般的な8ビットパラレルセントロニクスインタフェースではなく、IEEE1284規格の双方向セントロニクス(Bi-Cenntoronics)インタフェースを採用する。この双方向のセントロニクスインタフェースは、周辺機器におけるデータ受信だけでなく、その周辺機器からホストへのデータ送信も可能であり、双方向通信が可能なセントロニクスインタフェースである。また、IEEE1284規格にはいくつかのモードがあり、その中の1つとしてECPモードがある。このECPモードでは、8ビットパラレルデータを双方向に高速に送受信することが可能である。

【0014】また、近年、制御電圧の制御により消去、書き込みが可能な所謂フラッシュROMが開発されている。そこで、プリンタ内にマスクROM等の代わりにフラッシュROMを備え、前記の双方向通信インタフェースによりホストとの通信を行い、格納されているプログラムのバージョンアップ等を行うべく、そのホストからプリンタ内のフラッシュROMに対して、新たなプログラムをダウンロードする。これにより、プログラムのバージョンアップの度にROMを交換する必要は無くなる。

【0015】しかしながら、フラッシュROMを使用する際、プリンタの動作制御プログラムをフラッシュRO 50 Mにダウンロード中にFATAL ERRORや、電源

30

ダウン等が発生した場合には、フラッシュROMに格納 されているデータが破壊されている可能性が高いため、 プリンタを復旧できなくなることが予想される。従っ て、このような場合、外部装置からダウンロードした動 作制御プログラムの受信データとしての信頼性を保証す ることが重要である。そこで、以下に説明する各実施形 態では、動作制御プログラムをフラッシュROMに格納 する場合のデータとしての信頼性を確保する方法を中心 に説明する。

【0016】尚、本発明に係る外部装置(ホスト)から 受信したデータの信頼性確保の手法は、プリンタの動作 制御プログラムに限られるものではないことは言うまで もない。

# [0017]

【第1の実施形態】はじめに、プリンタの内部構成の概 要について、図1を参照して説明する。

【0018】図1は、本発明の第1の実施形態としての プリンタのブロック構成図である。同図に示すように、 プリンタ1000は、パーソナルコンピュータ等のホス トコンピュータ100に接続されている。また、ホスト コンピュータ100は、後述するプリンタ1000にダ ウンロードすべき動作制御プログラムを、例えば不図示 のモデムまたはターミナルアダプタ等を介して外部の通 信ネットワークから、或はフロッピーディスク、CDー ROM、DVD等の記録媒体から入手する。

【0019】プリンタ1000において、102は、プ リンタ1000に於ける動作、処理を制御するCPUで ある。103は、CPU102の制御プログラムや文字 フォント等各種データを格納するフラッシュメモリ(以 下、フラッシュROM)である。104は、各種データ を一時保存するためのRAMである。101は、ホスト コンピュータ100等の外部機器との間でIEEE12 8 4 規格に基づく双方向セントロニクスの通信プロトコ ルに基づき制御を行うインタフェース制御部である。1 05は、プリンタの設定状態、動作モード、エラーメッ セージ等を表示する表示部である。

【0020】尚、RAM104には、インタフェース制 御部101が制御する双方向セントロニクス通信におけ るホストコンピュータ100からの受信データ、或は送 信データを格納するためにも使用される。また、RAM 40 104には、プリンタ1000の電源投入等のリセット スタート時に、フラッシュROM103の各セクタ内に 格納しているモジュール毎のチェックサムも格納する。

【0021】106は、CPU102からの制御信号に 従って不図示の記録ヘッドに画像データを転送し、その 画像データを記録媒体に記録するHEAD駆動部であ る。107は、CPU102からの制御信号に従って不 図示の紙送りモータを駆動するLF駆動部である。10 8は、CPU102からの制御信号に従って不図示のキ ャリッジモータを駆動するCR駆動部である。LF駆動 50

部107及びCR駆動部108を制御することにより、 HEAD駆動部106の記録ヘッドは、記録媒体上を水 平方向・垂直方向に移動することができる。

【0022】次に、プリンタ1000内のフラッシュR OM103について、図2を参照して説明する。

【0023】図2は、本発明の第1の実施形態としての フラッシュROMのメモリ空間を示す図である。

【0024】同図に示すように、フラッシュROM10 3のメモリ空間は、複数のセクタブロックに区切られて 10 いる。これらのセクタブロックにおいて、ブート領域

(Boot Block) には、少なくとも、フラッシ ュROM103にホストコンピュータ100から受信し たプログラムを書き込むプログラム、ホストコンピュー タ100との間でIEEE1284規格のECPモード により双方向データ通信を行うプログラム、並びに後述 のダウンロード中に障害が発生した時にダウンロードシ ーケンスを強制終了させたり、表示部105に所定の表 示を行うエラー処理ルーチンプログラムが格納されてお り、変更禁止のプロテクトがかかられている。

【0025】また、フラッシュROM103の各セクタ ブロック(Block1~Block7)には、例え ば、プリンタ1000のプリンタエンジンの制御プログ ラム、マスクパターン、ヒートテーブル等のように、複 数のプログラムモジュールに分けられたプリンタ100 の動作制御プログラムと、その個々のモジュールのチェ ックサムが格納される。チェックサムは、プリンタ10 00の電源投入等のリセットスタート時にRAM104 に格納される。

【0026】更に、Boot Blockには、ダウン 30 ロードが正常に終了しなかったときにこのBoot B lockに格納されているプログラムにより他のセクタ が起動されないように、FATAL ERROR時の処 理プログラムも格納されている。

【0027】ホストコンピュータ100から送出される プリンタ1000の動作制御プログラムは、予めプリン タ1000の各動作に合わせてモジュール単位に分割さ れており、この分割された各モジュールはフラッシュR OM103にブロック単位で格納される。

【0028】以下、本実施形態おける動作制御プログラ ムの書き換え処理を、ホストコンピュータ100からプ リンタ1000へのプログラムモジュールのダウンロー ド処理と、プリンタ1000におけるフラッシュROM 103内の動作制御プログラムの書き換え処理とに分け て説明する。

【0029】<プログラムモジュールのダウンロード処 理>まず、本実施形態におけるホストコンピュータ10 0からプリンタ1000への動作制御プログラムのダウ ンロード処理の制御手順を、図3及び図4を参照して説 明する。

【0030】図3は、本発明の第1の実施形態としての

ダウンロードのシーケンスを示す図であり(正常終了の場合)、ホストコンピュータ100とプリンタ1000との間でIEEE1284規格のECPモードにより行われる。

【0031】ステップ(1):まず、ホストコンピュータ100よりプリンタ1000の動作制御プログラムをダウンロードする場合、ホストコンピュータ100からプリンタ1000にダウンロードの問い合わせを行う。

【0032】ステップ(2):ホストコンピュータ10 0からの問い合わせに対してプリンタ1000では、ダ 10 ウンロードの実行を要求する場合にはホストコンピュー タ100に「応答」を返す。このステータス応答は、前 述したフラッシュROM103のBoot Block に格納されている通信プログラムにより、インタフェー ス制御部101を介して行われる。

【0033】ステップ(3):次に、プリンタ1000から「応答」を返されたホストコンピュータ100は、新たにプリンタ1000にダウンロードする動作制御プログラムのバージョン番号または記号を送信する。

【0034】ステップ(4):プリンタ1000は、受 20 信したバージョン番号または記号を、現在フラッシュR OM103に格納されている動作制御プログラムのバージョン番号または記号と比較し、プリンタ1000内のバージョン番号または記号が古い場合には、ダウンロード要求ステータスを返す。

【0035】ステップ(5):ダウンロードの要求ステータスを受信したホストコンピュータ100は、プリンタ1000のフラッシュROM103内の各セクタに格納すべく、複数のモジュールに区切ってある動作制御プログラムのチェックサムをプリンタ1000に送信する。

【0036】ステップ(6):チェックサムを受信したプリンタ1000は、各セクタブロックに現在格納してあるチェックサムを電源投入等のリセットスタート時にRAM104に格納し直してあるため、このRAM104に格納してある各セクタのチェックサムと、今回ホストコンピュータ100から受信したチェックサムと比較し、異なるチェックサムのモジュールをホストコンピュータ100に知らせる。

【0037】ステップ(7),ステップ(8):ホストコンピュータ100は、プリンタ1000から応答のあったチェックサムの異なる動作制御プログラムのモジュールを、プリンタ1000にダウンロードする。その際、ホストコンピュータ100は、送出する動作制御プログラムのモジュールに含まれるデータ数をダウンロードするデータの最初に送信し、次にそのプログラムのモジュール、そしてそのチェックサムを送信する。

【0038】ステップ(9):プリンタ1000では、 順次プログラムデータが送られてくる度にチェックサム の計算が行われ、最後にホストコンピュータ100から 送られてくるチェックサムとプリンタ1000で計算されたチェックサムとを比較し、同じであれば正常終了の

れたチェックサムとを比較し、同じであれば正常終了のステータスをホストコンピュータ100に返す。尚、チェックサムは、フラッシュROM103の各セクタブロックにプログラムモジュールと共に格納する。

【0039】これらのステップ(7) ~ステップ(9) の通信は、ステップ(6) で受信した異なるチェックサムのモジュールの分だけ行われ、ダウンロードが終了する。

【0040】図4は、本発明の第1の実施形態としての ダウンロードのシーケンスを示す図であり(異常発生の 場合)、ダウンロードの途中でFATAL ERROR や、電源ダウン等の障害が発生し、ダウンロードが中断 した場合を示す。

【0041】同図において、図4のステップ(1)~ステップ(7)までは前述の図3の説明と同様のため、説明を省略する。

【0042】ステップ(8),ステップ(9):図4のステップ(7)において、プログラムのダウンロード中にプリンタ1000に予め設定されている通信タイムアウト時間を超えてもプログラムデータが送信されない場合、プリンタ1000は、ホストコンピュータ100等の異常とみなし、一旦ECPモードから抜け、Boot

Blockに予め格納してあるエラー処理ルーチンを 起動し、ダウンロードシーケンスを強制終了する。 また、ダウンロードシーケンスが強制終了されると、プリンタ1000の表示部105には、FATAL ERR ORが表示される。

【0043】更に、プリンタ1000は、異常が発生し
30 たときにホストコンピュータ100からのダウンロード
の途中であったプログラムモジュールのデータは、フラッシュROM103の当該セクタブロック内で破壊され
ている可能性が高いため、そのプログラムモジュールが
格納されているセクタブロックが次回の電源投入等のリセットスタート時に起動されないように、Boot Blockのプログラムを設定する。

【0044】その後、表示部105の表示を見たオペレータが、電源投入等によりプリンタ1000をリセットスタートさせると、それまでRAM104に格納されていた各セクタブロックのチェックサムはクリアされ、前述したように、フラッシュROM103に格納されているチェックサムがRAM104に新たに格納される。従って、RAM104には、データが破壊されているセクタブロックのチェックサムも格納される。

【0045】ステップ(10):プリンタ1000のリセットスタートによりホストコンピュータ100との通信が回復すると、ダウンロードの問い合わせがホストコンピュータ100からプリンタ1000になされる。

【0046】ステップ(11),ステップ(12):プ 50 リンタ1000では、ホストコンピュータ100にダウ

ンロードを要請すると共にエラー処理ルーチンから復帰し、ステップ(2)へと移行する。これにより、ホストコンピュータ100とのバージョン番号または記号及びチェックサムの相違の確認からダウンロードの制御が再開される。即ち、ホストコンピュータ100は、プリンタ1000のリセットスタートによりRAM104に格納されたところの、データが破壊されているセクタブロックのチェックサムを認識することができるため、障害の発生によりダウンロードが中断したプログラムモジュールからダウンロードが再開することができる。

【0047】 [第1の実施形態のダウンロード処理の変形例] 次に、図5を参照して第1の実施形態の変形例を説明する。

【0048】図5は、本発明の第1の実施形態の変形例としてのダウンロードのシーケンスを示す図である(正常終了の場合)。

【0049】上述した実施形態では、ダウンロード中に 障害が発生し、フラッシュROM103内のセクタブロックのデータが破壊されても、再度そのデータをダウンロードすることによりフラッシュROM103に格納す 20るデータの内容を保証した。本変形例では、ホストコンピュータ100から考ウンロードする前に、一度プリンタ100から書き換えられるプログラムモジュールとそのチェックサムとをホストコンピュータ100に転送し(6A,6B)、コンピュータ側で格納することにより、バージョンアップ前のデータ及びチェックサムを保存する。そして、ダウンロードが完了し、バージョンアップが終了した時点で、ホストコンピュータ100に格納したバージョンアップ前のデータ及びチェックサムを消去する。これにより、データの保存及び信頼性は更に 30向上させることができる。

<フラッシュROM内の動作制御プログラムの書き換え処理>次に、上述の手順でホストコンピュータ100から受信するプログラムモジュールを、どのような手順でフラッシュROM103内に書き込むかについて説明する。

【0050】図6は、本発明の第1の実施形態としての プリンタの動作制御プログラムの書き換えの手順を説明 する図である。

【0051】図12は、本発明の第1の実施形態として 40 のプリンタの動作制御プログラムの書き換え処理を示すフローチャートである。

【0052】図6の(a)から(c)のフラッシュROM103のBoot Blockには、前述したように、少なくとも、フラッシュROM103にホストコンピュータ100から受信したプログラムを書き込むプログラム、ホストコンピュータ100との間でIEEE1284規格のECPモードにより双方向データ通信を行うプログラム、並びに後述のダウンロード中に障害が発生した時にダウンロードシーケンスを強制終了させた

り、表示部105に所定の表示を行うエラー処理ルーチンプログラムが格納されており、変更禁止のプロテクトがかかられている。

10

【0053】また、図6(a)のBlock1からBlock4には、プリンタ1000のプリンタエンジンの制御プログラム、マスクパターン、ヒートテーブル、等が書き込まれている。この状態でプリンタが市場に投入され、その後、例えば高性能なインクが開発された場合を考える。このプリンタでは、ヒートパルス幅等を変更しなければならないので高性能なインクを利用することはできない。そこで、ヒートテーブルが書き込まれているBlock3のプログラムの書き換えを行うことにより(図6(c))、その高性能なインクが使用可能となる。その変更の手順を図12を参照して説明する。

【0054】ステップS1,ステップS2:プリンタ1000は、ホストコンピュータ100からBlock3のプログラム書き換えのコマンドを受信した場合、図6(b)に示すようにBlock3に格納しているデータを消去する。

(0055)ステップS3:そして、ホストコンピュータ100からBlock3用の新しいプログラムを受信し、その新しいプログラムをBlock3に書き込む。
 (10056)ホストコンピュータ100からコマンドの受信、プログラムのダウンロードは、前述したダウンロ

ードシーケンスに基づいて行われる。

【0057】以上説明したように、ダウンロード中の障害発生を考慮したダウンロードシーケンスを採用し、更に、動作制御プログラムをモジュール単位でフラッシュROM103の各セクタブロックに格納することにより、ダウンロード中に障害が発生した場合でも、フラッシュROM103内の最小限のプログラム破壊で済み、再度ダウンロードするときに全領域ダウンロードする必要がない。これにより、ホストコンピュータ1000から受信する動作制御プログラムの信頼性の確保が可能となる。

【0058】また、プリンタ1000において、障害発生時のエラー処理ルーチンをフラッシュROM103のブート領域に持つことにより障害発生後のプリンタの暴走を防止できる。

*40* 【0059】

【第2の実施形態】本実施形態は、フラッシュROM内の動作制御プログラムの書き換え処理に関する。また、本実施形態も図1のシステムを基にしており、プリンタ1000動作制御プログラムに、不具合やバージョンアップ等が必要な場合には、新たな動作制御プログラムをホストコンピュータ100からプリンタ1000にダウンロードする。そして、プリンタ1000は、新たに受信した動作制御プログラムをフラッシュROM103に書き込むのは同様である。

50 【0060】上述した第1の実施形態の図6(b)の時

点でプリンタ1000のパワーオフ等のトラブルがあった場合、次にプリンタ1000のパワーオンしたときには、プリンタが暴走する可能性がある。そこで、本実施形態では、その危険性を防止できる書き換えの手順を以下に説明する。尚、本実施形態において、プリンタ1000は、フラッシュROM103のアドレスを変換するアドレス変換回路(図8)を備えている。

【0061】図7は、本発明の第2の実施形態としての プリンタの動作制御プログラムの書き換えの手順を説明 する図である。

【0062】図13は、本発明の第2の実施形態としてのプリンタの動作制御プログラムの書き換え処理を示すフローチャートである。

【0063】図8は、本発明の第2の実施形態としてのプリンタ内のアドレス変換回路のブロック構成図である。同図に示すように、アドレス変換回路は、フラッシュROM103の各ブロックのアドレス比較回路(a)~(c)、アドレス生成回路(e)から(h)、並びにそれらの回路の接続を選択する選択回路(d)を備える。選択回路の制御は、CPU102が行うことは言うまでもない。

【0064】図9は、本発明の第2の実施形態としての プリンタ内のアドレス変換回路の内部接続の状態を示す 図である。

【0065】図7(a)において、フラッシュROM103のBoot Block及びBlock1からBlock3には、第1の実施形態と同様に書き込み禁止のブートプログラムとモジュール化された動作制御プログラムが格納されている。

【0066】但し、本実施形態では、BlocklからBlock3のブロックの内、一番大きい記憶容量のブロックと同等以上のサイズを有するバックアップ用の空き領域が設定されている。また、この時のアドレス変換回路(図8)の接続状態は、図9(i)である。

【0067】以下、書き換えの手順を図13を参照して 説明する。

【0068】ステップS11,ステップS12:ホストコンピュータ100から、例えば、Block2のプログラム書き換えのコマンドを受信した場合には、図7(b)に示すように、まず現在の空き領域に新しいBlock2を書き込む。

【0069】ステップS13,ステップS14:次に、プリンタ1000は、新しく書き込んだプログラムのチェックサムを計算し、算出したチェックサムとホストコンピュータ100から送られたチェックサムとを比較する。

【0070】ステップS15:ステップS14でチェックサムが一致しない場合は、ホストコンピュータ100に再送要求を送り、ステップS11に戻る。

【0071】ステップS16,ステップS17:一方、

ステップS14でチェックサムが一致した場合は、図8のアドレス変換回路の選択回路(d)を図9(j)のように設定する。これにより、Block2をアクセスした場合には、空き領域に書き込まれた新しいBlock2のプログラムがCPU102に読み込まれる(図7(b))。

【0072】また、図7(b)においてBlock2のデータを消去し、その領域を新たな空き領域とする(図7(c))。次に、図7(c)において元の空き領域に10保存されている新しいBlock2の内容を、現在の空き領域(元のBlock2)にコピーする(図7(d))。

【0073】ステップS18,ステップS19:そして、新しくB1ock2に書き込んだプログラムのチェックサムを計算し、そのチェックサムとホストコンピュータ100から送られたチェックサムとを比較する。

【0074】ステップS20:ステップS19でチェックサムが一致しない場合は、ホストコンピュータ100に当該プログラムの再送要求を行い、ステップS11に戻る。

【0075】ステップS21:一方、ステップS19でチェックサムが一致した場合は、図8のアドレス変換回路の選択回路(d)を図9(k)のように設定し、新しいBlock2のプログラムが格納されている領域を新たな空き領域とし、ステップS11に戻る。これにより、Block2をアクセスした場合には、新しいBlock2のプログラムがCPU102に読み込まれる(図7(e))。

【0076】ホストコンピュータ100からダウンロードすべきプログラムが複数有る場合は、上記の手順を繰り返す。尚、本実施形態においても、ホストコンピュータ100からコマンドの受信、プログラムのダウンロードは、第1の実施形態で説明したダウンロードシーケンスにより行われることは言うまでもない。

【0077】このように、上述した本実施形態は、書き換え処理の回数が第1の実施形態より増え、また、最大ブロックと同等のサイズの空き領域を必要とする。しかし、プリンタ1000の正常な動作に必要な動作制御プログラムが常にフラッシュROM103上に存在させることができる。従って、ダウンロード中に障害が発生しても、その後のプリンタ1000のリセットスタートによる暴走を防止できる。

# [0078]

【第3の実施形態】本実施形態も、フラッシュROM内の動作制御プログラムの書き換え処理に関する。特に、本実施形態は、第2の実施形態と同様、常に動作に必要なプログラムデータを確保しながら、ホストコンピュータ100から複数のプログラムモジュールをダウンロードする場合に、書き込み処理の回数の減少させるものである。以下、本実施形態では、2つのプログラムモジュ

30

ールをダウンロードする場合を例に説明する。

【0079】図10は、本発明の第3の実施形態として のプリンタの動作制御プログラムの書き換えの手順を説 明する図である。

【0080】図14は、本発明の第3の実施形態として のプリンタの動作制御プログラムの書き換え処理のフロ ーチャートである。

【0081】図11は、本発明の第3の実施形態として のプリンタ内のアドレス変換回路の内部接続の状態を示 す図である。

【0082】本実施形態においても、図10 (a) に示 すようにフラッシュROM103のBoot Bloc k及びBlocklからBlock3には、第1の実施 形態と同様に書き込み禁止のブートプログラムとモジュ ール化された動作制御プログラムが格納されている。ま た、この時のアドレス変換回路(図8)の接続状態は、 図11(i)である。

【0083】但し、本実施形態では、空き領域、及びB locklからBlock3の記憶容量は、何れも同じ 大きさの記憶容量に設定する。

【0084】以下、書き換えの手順を図14を参照して 説明する。

【0085】ステップS31,ステップS32:図10 (a) の状態の時、ホストコンピュータ100からBI ock2及びBlock3のプログラム書き換えのコマ ンドを受信した場合には、まず現在の空き領域に新しい Block2を書き込む(図10(b))。

【0086】ステップS33:そして、新しく書き込ん だプログラムのチェックサムを計算し、そのチェックサ ムとホストコンピュータ100から送られたチェックサ ムとを比較する。

【0087】ステップS35:ステップS34でチェッ クサムが一致しない場合は、ホストコンピュータ100 に当該プログラムの再送要求を行い、ステップS31に 戻る。

【0088】ステップS36:一方、ステップS34で チェックサムが一致した場合は、図8のアドレス変換回 路の選択回路(d)を図9(j)のように設定する。こ れにより、BIock2をアクセスした場合には、新し いBlock2のプログラムがCPU102に読み込ま 40 実行することによっても、達成されることは言うまでも れる(図10(b))。

【0089】また、図10(b)においてBlock2 のデータを消去し、その領域に新たな空き領域を生成す る(図10(c))。

【0090】ステップS37:ステップS31で複数の ブロックの書き換えコマンドを受信している場合は、ま だ書き換えていないブロックが有るかを判断する(この 例においては、Block3の書き換えが未だであ る)。書き換えが完了している場合は、ステップS31 に戻る。

14

【0091】ステップS38:一方、まだ書き換えてい ないブロック (本例の場合は、Block3) をステッ プS37で検出した場合は、ホストコンピュータ100 に当該Blockの新たなプログラムの送信を要求し、 ステップS31に戻る。

【0092】従って、上記の処理をBlock3につい て同様に行った結果、フラッシュROM103に以下の 状態を得る。

【0093】即ち、Block3のプログラムについて 10 上記の処理を行うことにより、本実施形態では、図

(c) の現在の空き領域に新たなBlock3のプログ ラムを格納し(図10(d))、古いBlock3のプ ログラムの領域を新たな空き領域とする (図10

(e))。その際、図8のアドレス変換回路の選択回路 (d) を図11 (j) から(k) のように設定する。こ れにより、BIock3をアクセスした場合は、新しい Block3のプログラムがCPU102に読み込まれ る。

【0094】尚、本実施形態においても、ホストコンピ ュータ100からコマンドの受信、プログラムのダウン ロードは、第1の実施形態で説明したダウンロードシー ケンスにより行われることは言うまでもない。

【0095】このように、本実施形態では、複数のプロ グラムモジュールをダウンロードした場合において、常 に動作に必要なプログラムデータを確保できる。また、 各ブロックを空き領域として利用するため、フラッシュ ROM103の書き込み処理の回数を第2の実施形態よ り少なくすることができる。

[0096]

ない。

30 【他の実施形態】尚、本発明は、複数の機器(例えばホ ストコンピュータ、インタフェイス機器、リーダ、プリ ンタ等) から構成されるシステムに適用しても、一つの 機器からなる装置(例えば、複写機、ファクシミリ装置 等) に適用してもよい。

【0097】また、本発明の目的は、前述した実施形態 の機能を実現するソフトウェアのプログラムコードを記 録した記憶媒体を、システム或は装置に供給し、そのシ ステム或は装置のコンピュータ(またはCPUやMP U) が記憶媒体に格納されたプログラムコードを読出し

【0098】この場合、記憶媒体から読出されたプログ ラムコード自体が前述した実施形態の機能を実現するこ とになり、そのプログラムコードを記憶した記憶媒体は 本発明を構成することになる。

【0099】プログラムコードを供給するための記憶媒 体としては、例えば、フロッピディスク、ハードディス ク,光ディスク,光磁気ディスク, CD-ROM, CD -R,磁気テープ,不揮発性のメモリカード, ROM等 50 を用いることができる。

15

【0100】また、コンピュータが読出したプログラムコードを実行することにより、前述した実施形態の機能が実現されるだけでなく、そのプログラムコードの指示に基づき、コンピュータ上で稼働しているOS(オペレーティングシステム)等が実際の処理の一部または全部を行い、その処理によって前述した実施形態の機能が実現される場合も含まれることは言うまでもない。

【0101】更に、記憶媒体から読出されたプログラムコードが、コンピュータに挿入された機能拡張ボードやコンピュータに接続された機能拡張ユニットに備わるメモリに書込まれた後、そのプログラムコードの指示に基づき、その機能拡張ボードや機能拡張ユニットに備わるCPU等が実際の処理の一部または全部を行い、その処理によって前述した実施形態の機能が実現される場合も含まれることは言うまでもない。

## [0102]

【発明の効果】以上説明したように、本発明によれば、 外部装置からの入力情報の信頼性の確保が可能な情報処 理装置及び情報格納方法の提供が実現する。

#### [0103]

#### 【図面の簡単な説明】

【図1】本発明の第1の実施形態としてのプリンタのブロック構成図である。

【図2】本発明の第1の実施形態としてのフラッシュR OMのメモリ空間を示す図である。

【図3】本発明の第1の実施形態としてのダウンロードのシーケンスを示す図である(正常終了の場合)。

【図4】 本発明の第1の実施形態としてのダウンロード

16

のシーケンスを示す図である(異常発生の場合)。

【図5】本発明の第1の実施形態の変形例としてのダウンロードのシーケンスを示す図である(正常終了の場合)。

【図 6 】本発明の第1の実施形態としてのプリンタの動作制御プログラムの書き換えの手順を説明する図である。

【図7】本発明の第2の実施形態としてのプリンタの動作制御プログラムの書き換えの手順を説明する図であ
10 る。

【図8】本発明の第2の実施形態としてのプリンタ内の アドレス変換回路のブロック構成図である。

【図9】本発明の第2の実施形態としてのプリンタ内のアドレス変換回路の内部接続の状態を示す図である。

【図10】本発明の第3の実施形態としてのプリンタの動作制御プログラムの書き換えの手順を説明する図である

【図11】本発明の第3の実施形態としてのプリンタ内のアドレス変換回路の内部接続の状態を示す図である。

【図12】本発明の第1の実施形態としてのプリンタの 動作制御プログラムの書き換え処理を示すフローチャー トである。

【図13】本発明の第2の実施形態としてのプリンタの動作制御プログラムの書き換え処理を示すフローチャートである。

【図14】本発明の第3の実施形態としてのプリンタの動作制御プログラムの書き換え処理のフローチャートである。







**-**○ (e)

(k)

(a) O (e) (a) O ---

(i)

-O(e) (a)O-

**(j)** 

【図13】



1. A . a . a

【図14】

